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1 Complexity Theory 


Let Factor be the decision problem where given a pair of integers (x, k), the goal is to 
decide whether x has a factor smaller than k. Let Factoring be the search problem, 
where given an integer x, the goal is to output a prime factorisation of x. (In the 
following, carefully note the distinction between Factor and Factoring.) 


(a) Prove that Factor € NPM coNP. [5 marks] 


(b) Prove that if P= NP McoNP, then there exists a polynomial-time algorithm for 
Factoring. [7 marks] 


(c) Define the class BQP. Is Factoring € BQP? [4 marks] 
(d) Show that a quantum (BQP) algorithm for a problem P, which is correct 
with probability 2/3 over the measurement, can be amplified into a quantum 


algorithm for P, which is correct with probability 1—o(1) over the measurement. 
[4 marks] 


2 Complexity Theory 


(a) Provide a precise definition of the following complexity classes: EXP, NEXP, and 


NPSPACE. [3 marks] 
(b) Prove that NPSPACE C EXP C NEXP. [7 marks] 
(c) Prove that if P = NP, then EXP = NEXP. [10 marks] 
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3 Computation Theory 


Define the collection of primitive recursive functions. [2 marks] 
What does it mean to say that a function f : N > N is A-definable. {2 marks] 


For each of these functions, show that it is primitive recursive and explain why 
it is \-definable. 


(i) fact(x) 4 al; [7 marks] 


[7 marks] 


z otherwise 


(ii) cond(2,y,z) = { y Lae 


Give an example of a function that is \-definable but not primitive recursive. 
You do not need to give a proof of the fact. [2 marks] 
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4 Computation Theory 
Let P be any register machine program. 


(a) What is the partial function f: N — N of one argument computed by P? 
[2 marks] 


(b) What is the partial function g: N? — N of two arguments computed by P? 
[2 marks] 


(c) Describe the construction of a Gédel numbering of register machine programs. 
That is, a bijection G between the natural numbers N and the collection of 
register machine programs. [5 marks] 


We now write ¢; : N — N for the partial function of one argument that is computed 
by the register machine program G(i), and 7; : N? — N for the partial function of 
two arguments that is computed by the register machine program G(i), where G is 
the Godel numbering constructed in part (c). 


(d) Show that the partial function u: N* — N defined by u(i,z) = ¢;(x) for all i 
and x is computable. You may assume standard results about register machine 
programs, as long as you state them in full and clearly. [5 marks] 


(e) Sketch a proof to show that there is a computable partial function s: N? — N 
such that, for all x,y, z,€ N: 


Ps(ey) (2) = Yay, Z): 
[6 marks] 
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5 Data Science 


In order to judge whether early prehistoric humans had some form of religious belief, 
archaeologists have proposed studying the alignment of graves in a burial site. The 
thinking is that if the graves all point in the same direction then the society must 
have had some form of supernatural belief which led them to align the graves in this 
way. However, we wouldn’t expect perfect alignment: the skeletal remains might be 
at an angle to the original grave; or there might be a mix of aligned and non-aligned 
graves from different waves of occupants. 


You have been asked by an archaeologist friend to conduct a hypothesis test of 
whether a collection of graves shows alignment. The dataset is a list [a1,...,2,] 
of angles, 0 < x; < 360 where 0 denotes North, 90 denotes East, and so on. 


(a) What is meant by a “null hypothesis”? What null hypothesis do you propose? 
[5 marks] 


(b) What is meant by a “test statistic”? What test statistic do you propose? Explain 
how your test statistic deals with the fact that 359.999 and 0 are very similar 
angles. 7 marks 


(c) What is meant by a “one-sided” or “two-sided” test? Which will you use? 
Explain your reasoning. 5 marks 


(d) Define “p-value”. Explain how to compute the p-value for your test. [3 marks 
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6 Data Science 
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This plot shows a collection of datapoints (x;,y;, group;) from two groups, together 
with fitted lines for each group. Based on our scientific understanding of the dataset, 
the lines should be parallel. 


(a) 


Describe a probability model and a fitting procedure that might be behind this 
plot. Explain how you enforce the ‘parallel lines’ requirement. Give pseudocode 
for the fitting procedure. Explain briefly how the plot is produced. [Note: 
When describing a probability model, you should state your assumptions: what 
probability distributions are you using, and why have you chosen them?| 

[7 marks] 


We would like to report our confidence about the offset between the two 
groups. Explain the Bayesian approach to computing this confidence, and give 
pseudocode. [7 marks] 


We have been asked to predict y at some new value x*, for both groups. 
Explain how to compute confidence intervals for these two predictions, and give 
pseudocode. [6 marks] 
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7 Logic and Proof 


A client wants a dispensing machine that sells two products, A and B. The following 
are some requirements: 


Pe 


In the default state a screen displays the two unselected products and it assumes 
no payment has been made. 


. Every time the machine is in the default state the user may select one and only 


one product. 


. It is always true that, given a selection, the user may pay for the selected product. 
. The selection can be changed provided that the user has not paid. 


. It is always possible to return to the default state. 


Once a product has been selected and paid for, the user gets the product. 


(a) 


Formalise statements 1 to 5 in S4 modal logic. Use letter A to represent the 
proposition that A is selected, B to represent that B is selected, D to represent 
the default state and P that a payment has been made. [6 marks] 


Model the default state as a world in a modal frame. Exhibit an interpretation 
that satisfies statements 1 to 5. [7 marks] 


Given your formalisation of statements 1 to 5, how would you formalise and 
prove (using the sequent calculus for $4) that, starting from the default state, 
it is possible for the user to get one of every product? Your answer can be 
schematic. A full formal proof is not necessary, but you must be clear about the 
strategy used. [Hint: Start by using the default state and statement 2 to prove 
that it is possible to select A.] [7 marks] 
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8 Logic and Proof 


(a) Consider the following formulae, where a, b and c are constants and v,w,2,y 
and z are variables: 


P(a,v) > 7AQ(b, w 


) 
“(> (6, x) A P(b, y)) 
A(aP(z, 2) AP(z, ¢)) (3) 


“—— 
Ke 


(i) Convert the formulae above into conjunctive normal form (CNF) and 
express the result as a set of clauses. State which rule you used for each 
conversion step. [3 marks] 


(72) Convert the clauses resulting from part (a)(z) into Kowalski form. 
[2 marks] 


(iii) Using the clauses resulting from part (a)(iz), give a resolution proof for 
them. Use clause (1) as the top clause. Indicate the selected literal(s), 


clause and substitution used at each step. [7 marks] 


(b) (4) Convert the following formulae into clauses: 


M—-(N->M) (4) 
M > (NV P) (5) 

N > (=Q A 7R) (6) 
P > (RA-7Q) (7) 

M (8) 


[2 marks] 


(ii) Use the DPLL method to find a model satisfying the clauses from part 
(b)(z), or to prove that no such model exists. Briefly explain your work in 
each step. [6 marks] 
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9 Semantics of Programming Languages 


(a) 


Suppose the types InputChannel(7), OutputChannel(7), and IOChannel(7) have 
the following API: 


read : InputChannel(7) > 7 
write : OutputChannel(7) x 7 > unit 


read : lOChannel(r) > 7 
write : IOChannel(7) x 7 — unit 


Note that read and write are overloaded functions. Define a suitable subtyping 
relation over the channel types. [5 marks] 


Consider the following two concurrent L1 programs: 


Program 1: r:=!r+1;r:=!r+1 


Program 2: r:=!r+2 


Are these two programs semantically equivalent in a concurrent setting? Give 
an informal but precise argument if they are, or give a counterexample if not. 
[2 marks] 


Suppose we try to introduce a safe file-handling API in a language with 
higher-order functions and state (such as L3) by introducing the function 
withFile : (File + unit) > unit. This function creates a file, passes the file to its 
callback, and then closes the file after the callback returns. Is there any way for 
a File object to outlive the callback invocation and leak into the environment? 
Either argue that the API is safe, or give a counterexample. [3 marks] 


We can define the prefix relation xs E ys on lists as follows: 


rs L ys 
[| © ys Pel ee ays 


(i) Prove that the prefix relation is reflexive. [3 marks] 


(72) Prove that the prefix relation is transitive. Inversion properties may be 
used without proof, as long as they are explicitly indicated. [7 marks] 
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10 Semantics of Programming Languages 


Regular expressions are defined by the following grammar: 


= Matches the single-character word ¢ 
| € Matches the empty word 
| 1r,0org Matches the concatenation of an rj-word and an rg-word 
| 0 Matches no words 
| 1r,+7r2 Matches any r,-word or ro-word 
ie ee Matches the concatenation of a finite number of r-words 


Give a set of inference rules defining a relation for when a word w is matched 
by a regular expression r. Use the notation w-w’ to denote concatenation. 


[8 marks] 


(i) Using the matching relation defined above, define a suitable notion of 
semantic equivalence r; ~ rz for regular expressions. [4 marks] 


(ii) Use this definition to prove that (r+r’) ~ (r’+r). You may use inversion 
lemmas without proof, as long as they are explicitly indicated. [4 marks] 


Define an inductive relation r null characterizing the regular expressions r for 
which € in r. [4 marks] 


END OF PAPER 
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